## CompactRISC16 (CR16) Instruction Set Architecture (ISA)

Computer Design Laboratory ECE 3710 Group 2 Fall 2021 The University of Utah

Table 1: Assembly Instructions and Machine Encodings

|              |                  |                                         |         |           | ImmHi/     | ImmLo/  |                                                                                                                              |
|--------------|------------------|-----------------------------------------|---------|-----------|------------|---------|------------------------------------------------------------------------------------------------------------------------------|
|              |                  |                                         | Opcode  | Rdest     | Opcode Ext | Rsrc    |                                                                                                                              |
| Mnemonic     | Operands         | Function                                | [15:12] | [11:8]    | [7:4]      | [3:0]   | Notes                                                                                                                        |
| ADD          | Rdest, Rsrc      | Rdest = Rdest + Rsrc                    | 0000    | Rdest     | 0000       | Rsrc    |                                                                                                                              |
| ADDI         | Rdest, Imm       | Rdest = Rdest + Imm                     | 0001    | Rdest     | ImmHi      | ImmLo   | Sign extended Imm                                                                                                            |
| ADDC         | Rdest, Rsrc      | Rdest = Rdest + Rsrc + 1                | 0000    | Rdest     | 0001       | Rsrc    |                                                                                                                              |
| ADDCI        | Rdest, Imm       | Rdest = Rdest + Imm + 1                 | 0010    | Rdest     | ImmHi      | ImmLo   | Sign extended Imm                                                                                                            |
| MUL          | Rdest, Rsrc      | Rdest = Rdest * Rsrc                    | 0000    | Rdest     | 0010       | Rsrc    |                                                                                                                              |
| MULI         | Rdest, Imm       | Rdest = Rdest * Imm                     | 0011    | Rdest     | ImmHi      | ImmLo   | Sign extended Imm                                                                                                            |
| SUB          | Rdest, Rsrc      | Rdest = Rdest - Rsrc                    | 0000    | Rdest     | 0011       | Rsrc    |                                                                                                                              |
| SUBI         | Rdest, Imm       | Rdest = Rdest - Imm                     | 0100    | Rdest     | ImmHi      | ImmLo   | Sign extended Imm                                                                                                            |
| CMP          | Rdest, Rsrc      | Rdest - Rsrc                            | 0000    | Rdest     | 0100       | Rsrc    |                                                                                                                              |
| CMPI         | Rdest, Imm       | Rdest - Imm                             | 0101    | Rdest     | ImmHi      | ImmLo   | Sign extended Imm                                                                                                            |
| NOT          | Rdest, Rsrc      | Rdest = !Rdest                          | 0000    | Rdest     | 0101       | xxxx    |                                                                                                                              |
| NOTI         | Rdest, Imm       | Rdest = !Imm                            | 0110    | Rdest     | ImmHi      | ImmLo   | Zero extended Imm                                                                                                            |
| AND          | Rdest, Rsrc      | Rdest = Rdest & Rsrc                    | 0000    | Rdest     | 0110       | Rsrc    |                                                                                                                              |
| ANDI         | Rdest, Imm       | Rdest = Rdest & Imm                     | 0111    | Rdest     | ImmHi      | ImmLo   | Zero extended Imm                                                                                                            |
| OR           | Rdest, Rsrc      | Rdest = Rdest   Rsrc                    | 0000    | Rdest     | 0111       | Rsrc    | NOP instruction is OR<br>R0, R0                                                                                              |
| ORI          | Rdest, Imm       | Rdest = Rdest   Imm                     | 1000    | Rdest     | ImmHi      | ImmLo   | Zero extended Imm                                                                                                            |
| XOR          | Rdest, Rsrc      | Rdest = Rdest ^ Rsrc                    | 0000    | Rdest     | 1000       | Rsrc    |                                                                                                                              |
| XORI         | Rdest, Imm       | Rdest = Rdest ^ Imm                     | 1001    | Rdest     | ImmHi      | ImmLo   | Zero extended Imm                                                                                                            |
| LSH          | Rdest, Ramount   | Rdest = Rdest << Ramount                | 0000    | Rdest     | 1001       | Ramount | $0 \le \text{Ramount} \le 15 \text{ since}$ registers are only 16-bits                                                       |
| LSHI         | Rdest, ImmLo     | Rdest = Rdest << Imm                    | 0000    | Rdest     | 1010       | ImmLo   | $0 \le \text{ImmLo} \le 15$                                                                                                  |
| RSH          | Rdest, Ramount   | Rdest = Rdest >> Ramount                | 0000    | Rdest     | 1011       | Ramount | $0 \le \text{Ramount} \le 15$                                                                                                |
| RSHI         | Rdest, ImmLo     | Rdest = Rdest >> Imm                    | 0000    | Rdest     | 1100       | ImmLo   | $0 \le \text{ImmLo} \le 15$                                                                                                  |
| ALSH         | Rdest, Ramount   | Rdest = Rdest <<< Ramount               | 0000    | Rdest     | 1101       | Ramount | $0 \le \text{Ramount} \le 15$                                                                                                |
| ALSHI        | Rdest, ImmLo     | Rdest = Rdest <<< Imm                   | 0000    | Rdest     | 1110       | ImmLo   | $0 \le \text{ImmLo} \le 15$                                                                                                  |
| ARSH         | Rdest, Ramount   | Rdest = Rdest >>> Ramount               | 0000    | Rdest     | 1111       | Ramount | $0 \le \text{Ramount} \le 15$                                                                                                |
| ARSHI        | Rdest, Imm       | Rdest = Rdest >>> Imm                   | 1111    | Rdest     | 0000       | ImmLo   | $0 \le \text{ImmLo} \le 15$                                                                                                  |
| MOV          | Rdest, Rsrc      | Rdest = Rsrc                            | 1111    | Rdest     | 0001       | Rsrc    | Copies Rsrc into Rdest                                                                                                       |
| MOVIL        | Rdest, Lower Imm | Rdest[7:0] = Imm                        | 1010    | Rdest     | ImmHi      | ImmLo   | Zero extended Imm,<br>moves immediate value<br>into lower bits of Rdest                                                      |
| MOVIU        | Rdest, Upper Imm | Rdest[15:8] = Imm                       | 1011    | Rdest     | ImmHi      | ImmLo   | Zero padded Imm, moves<br>immediate value into up-<br>per bits of Rdest                                                      |
| J[condition] | Rtarget          | <pre>if [condition]: PC = Rtarget</pre> | 1111    | condition | 0010       | Rtarget | [condition] bit patterns are in Table 2.                                                                                     |
| B[condition] | Displacement Imm | if [condition]:<br>PC += Imm            | 1100    | condition | ImmHi      | ImmLo   | [condition] bit patterns are in Table 2. Immediate is sign extended 2's complement for program counter/address displacement. |
| CALL         | Rtarget          | Pushes PC onto stack,<br>PC = Rtarget   | 1111    | xxxx      | 0011       | Rtarget | Used for nested subroutines                                                                                                  |

| CALLD  | Displacement Imm | Pushes PC onto stack,<br>PC += Imm      | 1101 | ImmHi | ImmMid | ImmLo | Used for nested subroutines. Immediate is sign extended 2's complement for program counter/address displacement. |
|--------|------------------|-----------------------------------------|------|-------|--------|-------|------------------------------------------------------------------------------------------------------------------|
| RET    |                  | Pops top of stack into PC, PC++         | 1111 | xxxx  | 0100   | xxxx  | Used to return from nested subroutine                                                                            |
| LPC    | Rdest            | Rdest = PC                              | 1111 | Rdest | 0101   | xxxx  | Sets Rdest to the current instruction address/PC                                                                 |
| LSF    | Rdest            | Rdest[4:0] = status flags               | 1111 | Rdest | 0110   | xxxx  | Sets 5 least significant<br>bits of Rdest to the cur-<br>rent status flags                                       |
| SSF    | Rsrc             | Status flags = Rsrc[4:0]                | 1111 | xxxx  | 0111   | Rsrc  | Sets current status flags<br>to 5 least significant bits<br>of Rsrc                                              |
| PUSH   | Rsrc             | rsp, Main memory value<br>at rsp = Rsrc | 1111 | xxxx  | 1000   | Rsrc  | Pushes Rsrc onto top of stack                                                                                    |
| POP    | Rdest            | Rdest = Main memory value at rsp, rsp++ | 1111 | Rdest | 1001   | xxxx  | Pops top of stack into<br>Rdest                                                                                  |
| LOAD   | Rdest, Raddr     | Rdest = Main memory value<br>at Raddr   | 1111 | Rdest | 1010   | Raddr | Used to load data at<br>Raddr into Rdest from<br>main memory                                                     |
| STORE  | Raddr, Rsrc      | Main memory value at<br>Raddr = Rsrc    | 1111 | Raddr | 1011   | Rsrc  | Used to store data at<br>Raddr from Rsrc to main<br>memory                                                       |
| LOADX  | Rdest, Raddr     | Rdest = External memory<br>at Raddr     | 1111 | Rdest | 1100   | Raddr | Used to load data at<br>Raddr into Rdest from<br>external/peripheral mem-<br>ory/registers                       |
| STOREX | Raddr, Rsrc      | External memory value at Raddr = Rsrc   | 1111 | Raddr | 1101   | Rsrc  | Used to store data at<br>Raddr from Rsrc to ex-<br>ternal/peripheral memo-<br>ry/registers                       |
| NOP    |                  | No Operation                            |      |       |        |       | Pseudo instruction for:<br>OR R0, R0                                                                             |

Table 2: Bit Patterns of Conditions for B[condition] and J[condition]

| Mnemonic | Bit Pattern | Description            | Function                | Status Flags |
|----------|-------------|------------------------|-------------------------|--------------|
| EQ       | 0000        | Equal                  | Rsrc == Rdest           | Z=1          |
| NE       | 0001        | Not Equal              | Rsrc != Rdest           | Z=0          |
| CS       | 0010        | Carry Set              | C == 1                  | C=1          |
| CC       | 0011        | Carry Clear            | C == 0                  | C=0          |
| FS       | 0100        | Flag Set               | F == 1                  | F=1          |
| FC       | 0101        | Flag Clear             | F == 0                  | F=0          |
| LT       | 0110        | Less Than              | signed: Rsrc < Rdest    | N=0 and Z=0  |
| LE       | 0111        | Less than or Equal     | signed: Rsrc <= Rdest   | N=O          |
| LO       | 1000        | Lower than             | unsigned: Rsrc < Rdest  | L=0 and Z=0  |
| LS       | 1001        | Lower than or Same as  | unsigned: Rsrc <= Rdest | L=0          |
| GT       | 1010        | Greater Than           | signed: Rsrc > Rdest    | N=1          |
| GE       | 1011        | Greater than or Equal  | signed: Rsrc >= Rdest   | N=1 or Z=1   |
| HI       | 1100        | Higher than            | unsigned: Rsrc > Rdest  | L=1          |
| HS       | 1101        | Higher than or Same as | unsigned: Rsrc >= Rdest | L=1 or Z=1   |
| UC       | 1110        | Unconditional          |                         | N/A          |
|          | 1111        | Never Jump             |                         | N/A          |

Table 3: Register Naming and Conventions

| Register Index | Register Name | Meaning                                                                                                                 |
|----------------|---------------|-------------------------------------------------------------------------------------------------------------------------|
| 4'd15          | rsp           | Stack pointer with an address starting at $0xFFFF$ ( $2^{16}$ ) and grows downward towards dynamically allocated memory |
| 4'd14          | r14           | 4th subroutine argument                                                                                                 |
| 4'd13          | r13           | 3rd subroutine argument                                                                                                 |
| 4'd12          | r12           | 2nd subroutine argument                                                                                                 |
| 4'd11          | r11           | 1st subroutine argument                                                                                                 |
| 4'd10          | r10           | Return value of subroutine                                                                                              |
| 4'd9           | r9            | Caller-owned                                                                                                            |
| 4'd8           | r8            | Caller-owned                                                                                                            |
| 4'd7           | r7            | Caller-owned                                                                                                            |
| 4'd6           | r6            | Caller-owned                                                                                                            |
| 4'd5           | r5            | Callee-owned                                                                                                            |
| 4'd4           | r4            | Callee-owned                                                                                                            |
| 4'd3           | r3            | Callee-owned                                                                                                            |
| 4'd2           | r2            | Callee-owned                                                                                                            |
| 4'd1           | r1            | Callee-owned                                                                                                            |
| 4'd0           | r0            | Callee-owned                                                                                                            |